Namespaces
Variants

std::literals::chrono_literals:: operator""d

From cppreference.net
Definiert im Header <chrono>
constexpr std:: chrono :: day operator "" d ( unsigned long long d ) noexcept ;
(seit C++20)

Bildet ein std::chrono::day Literal, das einen Tag des Monats im Kalender repräsentiert.

Inhaltsverzeichnis

Parameter

d - der Tageswert

Rückgabewert

Ein std::chrono::day , das d speichert. Wenn d > 255 , ist der gespeicherte Wert nicht spezifiziert.

Mögliche Implementierung

constexpr std::chrono::day operator ""d(unsigned long long d) noexcept
{
    return std::chrono::day(d);
}

Hinweise

Dieser Operator ist im Namensraum std :: literals :: chrono_literals deklariert, wobei sowohl literals als auch chrono_literals Inline-Namensräume sind. Der Zugriff auf diesen Operator kann erfolgen durch:

  • using namespace std :: literals ,
  • using namespace std :: chrono_literals , oder
  • using namespace std :: literals :: chrono_literals .

Zusätzlich wird innerhalb des Namespace std :: chrono die Direktive using namespace literals :: chrono_literals ; von der Standardbibliothek bereitgestellt, sodass wenn ein Programmierer using namespace std :: chrono ; verwendet, um Zugriff auf die Klassen in der Chrono-Bibliothek zu erhalten, die entsprechenden Literaloperatoren ebenfalls sichtbar werden.

Beispiel

#include <chrono>
#include <iostream>
int main()
{
    using namespace std::literals::chrono_literals;
    std::cout << static_cast<unsigned>(42d) << '\t' << 42d << '\n'
              << static_cast<unsigned>(256d) << '\t' << 256d << '\n' // unspecified
              << static_cast<unsigned>(298d) << '\t' << 298d << '\n'; // unspecified
}

Mögliche Ausgabe:

42      42 ist kein gültiger Tag
0       00 ist kein gültiger Tag
42      42 ist kein gültiger Tag

Siehe auch

konstruiert einen day
(öffentliche Elementfunktion von std::chrono::day )
ruft den gespeicherten Tageswert ab
(öffentliche Elementfunktion von std::chrono::day )